.component {
	padding-bottom: calc(20vh + env(safe-area-inset-bottom));
	background: #f2f3f5;

	.banner-container {
		width: 100vw;
		height: 334rpx;
		.swiper {
			width: 100%;
			height: 100%;
			.swiper-item {
				width: 100%;
				height: 100%;
				.image {
					width: 100%;
					height: 100%;
				}
			}
		}
	}

	.contract-kefu-btn {
		display: flex;
		justify-content: flex-end;
		transform: translateY(-35rpx);
		> .content {
			box-shadow: 0 2px 6px 0 rgba(0, 0, 0, 0.12);
			background-color: rgba(255, 255, 255, 0.85);
			border-radius: 35rpx 0 0 35rpx;
			display: flex;
			align-items: center;
			height: 70rpx;
			width: 342rpx;
			padding-left: 170rpx;
			position: relative;
			box-sizing: border-box;
			.icon {
				width: 100rpx;
				height: 100rpx;
				position: absolute;
				left: 50rpx;
				bottom: 20rpx;
			}
			.text {
				font-size: 32rpx;
				font-weight: bold;
			}
		}
	}

	.app-list {
		display: flex;
		margin-left: 30rpx;
		padding-right: 30rpx;
		.app-item {
			width: 0;
			flex: 1;
			.image {
				width: 100%;
			}
		}
		.app-item:not(:last-child) {
			margin-right: 30rpx;
		}
	}

	.article-list {
		margin-top: 30rpx;
		padding: 0 30rpx;
		> .title {
			display: flex;
			align-items: center;
			.point {
				width: 10rpx;
				height: 32rpx;
				background: #54bd81;
			}
			.text {
				font-weight: bold;
				font-size: 36rpx;
				margin-left: 10rpx;
				line-height: 1;
			}
		}

		> .content {
			margin-top: 20rpx;
			border-radius: 14rpx;
			overflow: hidden;
			> .header {
				padding-top: 6rpx;
				padding-left: 40rpx;
				padding-right: 50rpx;
				padding-bottom: 6rpx;
				display: flex;
				align-items: center;
				background: linear-gradient(to bottom, #fde8d5, #fffdfc);
				width: 100%;
				box-sizing: border-box;
				position: relative;
				> .title {
					font-size: 30rpx;
					color: #c44518;
					flex: 1;
					width: 0;
				}
			}
			> .list {
				padding: 0 40rpx;
				background: linear-gradient(to bottom, #fffdfc, #ffffff);
				> .item:not(:last-child) {
					border-bottom: 2rpx solid #f2f3f5;
				}
				> .item {
					padding: 20rpx 0;
					display: flex;
					> .icon {
						width: 164rpx;
						height: 150rpx;
					}
					> .right {
						width: 0;
						flex: 1;
						display: flex;
						flex-direction: column;
						justify-content: space-between;
						margin-left: 20rpx;
						> .top {
							> .article-title {
								font-size: 30rpx;
								//文本最多两行，超出部分加省略号
								overflow: hidden;
								text-overflow: ellipsis;
								display: -webkit-box;
								-webkit-line-clamp: 2;
								-webkit-box-orient: vertical;
							}
							> .release-date {
								font-size: 28rpx;
								margin-top: 10rpx;
								color: #808080;
							}
						}
						> .bottom {
							display: flex;
							align-items: center;
							> .label-list {
								width: 0;
								flex: 1;
								display: flex;
								> .label-item {
									font-size: 28rpx;
									margin-right: 20rpx;
								}
							}
							> .right-arrow-icon {
								width: 50rpx;
								height: 50rpx;
							}
						}
					}
				}
			}
		}
	}
	
	> .contract-kefu-float {
		position: fixed;
		bottom: 10vh;
		right: 0;
		.content {
			box-shadow: 0 2px 6px 0 rgba(0,0,0,0.12);
			position: relative;
			background: white;
			border-radius: 35rpx 0 0 35rpx;
			height: 70rpx;
			display: flex;
			flex-direction: column;
			justify-content: flex-end;
			padding: 0 30rpx;
			.icon {
				position: absolute;
				left: 50%;
				transform: translateX(-50%);
				bottom: 40rpx;
				width: 90rpx;
				height: 90rpx;
			}
			.text {
				font-size: 30rpx;
				font-weight: bold;
			}
		}
	}
}
